package com.study.mapper;

import com.study.pojo.dto.User;
import org.apache.ibatis.annotations.Insert;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Select;

import java.util.List;

@Mapper
public interface UserMapper {

    /**
     * 查询所有用户
     *
     * @return 用户列表
     */
    @Select("select * from tb_user")
    List<User> getUsers();

    /**
     * 注册用户
     *
     * @param user
     * @return 成功返回影响条数 否则返回-1
     */
    @Insert("insert into tb_user(username, password, name, code) values (#{username}, #{password}, #{name}, #{code})")
    int register(User user);

    /**
     * 登陆
     *
     * @param username
     * @param password
     * @return 成功返回此用户 否则null
     */
    User login(@Param("username") String username, @Param("password") String password);

    /**
     * 查询用户名是否已经存在
     *
     * @param username
     * @return 已经在返回 1 否则 0
     */
    @Select("select count(*) from tb_user where username=#{username}")
    int usernameExist(@Param("username") String username);

    /**
     * 根据username查询用户
     *
     * @param username
     * @return 返回找到的用户
     */
    @Select("select * from tb_user where username=#{username};")
    User queryUserByUsername(@Param("username") String username);

}
